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1 . A computer program product encoding a computer program for executing on a 
computer system a computer process for building compel garbage collection tables adapted for 
use in reclaiming memory from a heap during runtime, the computer process comprising: 

generating a first call site table storing ca}r site identifiers; 

generating a final descriptor table storing a set of unique descriptors, at least one unique 
descriptor describing a location of a pointer into the heap; and 

generating a descriptor reference table associated with the first call site table, each entry 
in the descriptor reference table mapping a call site identifier in the first call site table to one of 
the unique descriptors in the fWl descriptor table. 

2. The computer program product of claim 1 wherein at least two call site identifiers are 
mapped to the same unique descriptor in the final descriptor table. 

3. The computer pro|(r^^raductof claim 1 wherein the final descriptor table contains 
no identical i 

4. The computer progr^lfproduct of claim 1 wherein the operation of generating a first 
call site table comprise^ 

storing return addresses for one or more call sites into the call site table. 
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5. The computer program product of claim 1 wherein the operation of generating a final 
descriptor table comprises: 

generating an initial descriptor table including at least two identical descriptors, each 
descriptor in the initial descriptor table corresponding with a call site identifier in the call site 
table; 

copying each descriptor from the initial descriptor table to the^final descriptor table, if the 
descriptor is not identical to another descriptor already copied to tjie final descriptor table. ^ 

6. The computer program product of claim 1 whereiiyrhe operation of generating a 
descriptor reference table comprises: 

generating a table pair including a second call sit£ table and an initial descriptor table, the 
initial descriptor table storing descriptors that include'at least two identical descriptors; 

sorting the table pair based on the descriptj/rs in the initial descriptor table to provide a 
sorted table pair; 

traversing sequentially through the descriptors in the sorted table pair to associate a 
reference to each call site in the second c^Il site table, the reference being modified when a 
unique descriptor is encountered in the^nitial descriptor table; 

identifying each call site identifier in the second call site table to w Ach each reference is 
associated; and 

storing each reference /nto the descriptor reference table in association with the call site 
identifier identified in the identifying operation. 



7. The computer program product of claim 6 wherein the reference is an ordinal 

identifier of unique descriptors being processed during the traversing operation. 
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8. The computer program product of claim 7 wherein the traversing opeptuon 
comprises: 

incrementing the ordinal identifier when a unique descriptor^ encountered in the initial 
descriptor table. 

9. The computer program product of claim 6 ymerein the reference includes a pointer to 
one of the unique descriptors stored in the final descriptor table. 



10. The computer program pro^dct of claim 9 wherein the traversing operation 
comprises: 

designating as the reference a new pointer to one of the unique descriptors in the final 

kQ descriptor table when a unique descriptor is encountered in the initial descriptor table. 
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1 1 . A computer-readable medium having stored thereon compact garbage collepuon 
tables for identifying elements of a root set used in reclaiming memory from a he/tp during 
runtime, the compact garbage collection tables comprising: 

a call site table storing call site identifiers; 

a final descriptor table storing a set of unique descriptors, e^ch unique descriptor 
describing a location of a pointer into the heap, at least one descriptor identifying an element of 
the root set; and 

a descriptor reference table associated with/fhe call site table, each entry in the descriptor 
reference table mapping a call site identifier^m the call site table to a unique descriptor in the 
descriptor table. 

12. The computer readable medium of claim 1 1 wherein at least two call site identifiers of 
the call site table are m^ped to the same unique descriptor in the descriptor table. 




13. The computer rea 
identical des 



mm of claim 1 1 wherein the descriptor table contains no 
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14. A method of building compact garbage collection tables adapted for use in reclaiming 
memory from a heap during runtime, the method comprising: 

generating a first call site table storing call site identifier^; 

generating a final descriptor table storing a set of unique descriptors, at least one unique 
5 descriptor describing a location of a pointer into the he^ip; and 

generating a descriptor reference table associated with the first call site table, each entry 
in the descriptor reference table mapping a caM site identifier in the first call site table to one of 
the unique descriptors in the final descriptor table. 

? 15. The method of claim lXwherein at least two call site identifiers of the first call site 

ljl table are mapped to the sam^unique descriptor in the final descriptor table. 




nTKefinaf descriptor table contains no identical 



17. The method of claim 14 wherein the operation op^enerating a first call site table 



comprises: 

storing return addresses for one optfiore call sites into the call site table. 

18. The method of cl^im 14 wherein the operation of generating a final descriptor table 
comprises: 

genenrtirfg an initial descriptor table including at least two identical descriptors, each 
descripjOT in the initial descriptor table corresponding with a call site identifier in the call site 
5 t^le; and 
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copying each descriptor from the initial descriptor table to the final descriptor table, if the 
descriptor is not identical to another descriptor already copied to the final descriptortable. 

19. The method of claim 14 wherein the operation of generating a descriptor reference 
table comprises: / 

generating a table pair including a second call site table and an initial descriptor table, the 
initial descriptor table storing descriptors that include at least two identical descriptors; 

sorting the table pair based on the descriptors in the initial descriptor table to provide a 
sorted table pair; / 

traversing sequentially through the descriptors irt^xhe sorted table pair to associate a 
reference to each call site in the second call site tabhs, the reference being modified when a 
unique descriptor is encountered in the initial descriptor table; 

identifying each call site identifier in>me second call site table to which each reference is 
associated; and / 

storing each reference into thp descriptor reference table in association with the call site 
identifier identified in the identifying operation. 

20. The method of claim 19 wherein the reference is an ordinal identifier of the descriptor 
and call site identifier being processed during the traversal of the sorted table pair. 

21. The m#hod of claim 20 wherein the traversing operation comprises: 
incrementing the ordinal identifier when a unique descriptor is encountered in the initial 

descriptor/fable. 
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22. The method of claim 19 wherein the reference incluj&s a pointer to one of the unique 
descriptors stored in the final descriptor table. 

23. The method of claim 22 whereiaihe traversing operation comprises: 
designating as the reference a new pointer to one of the unique descriptors in the final 

descriptor table whejj^imique descriptor is encountered in the initial descriptor table. 
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24. A computer program product encoding a computer program for executing on a 
computer system a computer process for identifying elements of a root s# for garbage collection 
using compact garbage collection tables, the computer process comprising: 

locating a call site identifier in a call site table; 

identifying a descriptor reference in a descriptor jelference table, the descriptor reference 
being associated with the call site identifier; 

identifying a descriptor referenced by descriptor reference, the descriptor reference 
mapping between the call site identifier and the descriptor, the descriptor being one descriptor of 
a set of unique descriptors in a descriptor table; and 

accessing the descriptor ^determine the elements of the root set for garbage collection. 

25. The computer program product of claim 24 wherein the descriptor is mapped to at 
least two call site identfriers in the call site table. 

26. The computerpp^tnTproduct of claim 24 wherein the descriptor table contains no 
identical-descriptors. 

27. The computer program pjotnict of claim 24 wherein the descriptor reference includes 
an index into the descriptor i 



28. The coiptfuter program product of claim 24 wherein the descriptor reference includes 
a pointer into"fhe descriptor table. 
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29. A runtime system for identifying elements of a roofset for a garbage collection using 
compact garbage collection tables, the runtime system comprising: 

a garbage collector accessing a call site tabte'storing call site identifiers; 

a descriptor table storing a set of unique descriptors, each unique descriptor describing a 
location of a pointer into the heap, and / 

a descriptor reference table^ssociated with the call site table to identify elements of a root 
set, each entry in the descripjdr reference table mapping one of the call site identifiers in the call 
site table to a descriptorm the descriptor table, at least one descriptor in the descriptor table 
being mapped to ^plurality of call site identifiers. 

30. The runtimejystem-OTcIaim 29 wherein the descriptor table contains no identical 
descriptofsT^ 
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31. A method of identifying elements of a root set for garbage collection using compact 
garbage collection tables, the method comprising: 

locating a call site identifier in a call site table; 

identifying a descriptor reference in a descriptor reference table, the descriptor reference 
5 being associated with the call site identifier; 

identifying a descriptor referenced by the descriptor reference, the descriptor reference 
mapping between the call site identifier and the descriptor, the descriptor being one descriptor of 
a set of unique descriptors in a descriptor table; and 
^ accessing the descriptor to determine the elements of the root set for garbage collection. 
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32. The method of claim 31 wherein the descriptor is mapped to at least two call site 



identifiers in the call site table. 
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33. The method of claii 



herein the descriptor table contains no identical descriptors. 




